
// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements.  See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership.  The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License.  You may obtain a copy of the License at
// 
//   http://www.apache.org/licenses/LICENSE-2.0
// 
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied.  See the License for the
// specific language governing permissions and limitations
// under the License.

/**
 * AUTO-GENERATED FILE. DO NOT MODIFY.
 */

// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements.  See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership.  The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License.  You may obtain a copy of the License at
// 
//   http://www.apache.org/licenses/LICENSE-2.0
// 
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied.  See the License for the
// specific language governing permissions and limitations
// under the License.
import * as zrUtil from 'zrender/lib/core/util.js';
import SeriesData from '../../data/SeriesData.js';
import Graph from '../../data/Graph.js';
import linkSeriesData from '../../data/helper/linkSeriesData.js';
import prepareSeriesDataSchema from '../../data/helper/createDimensions.js';
import CoordinateSystem from '../../core/CoordinateSystem.js';
import createSeriesData from './createSeriesData.js';
import { convertOptionIdName } from '../../util/model.js';
export default function createGraphFromNodeEdge(nodes, edges, seriesModel, directed, beforeLink) {
	// ??? TODO
	// support dataset?
	var graph = new Graph(directed);

	for (var i = 0; i < nodes.length; i++) {
		graph.addNode(zrUtil.retrieve( // Id, name, dataIndex
			nodes[i].id, nodes[i].name, i), i);
	}

	var linkNameList = [];
	var validEdges = [];
	var linkCount = 0;

	for (var i = 0; i < edges.length; i++) {
		var link = edges[i];
		var source = link.source;
		var target = link.target; // addEdge may fail when source or target not exists

		if (graph.addEdge(source, target, linkCount)) {
			validEdges.push(link);
			linkNameList.push(zrUtil.retrieve(convertOptionIdName(link.id, null), source + ' > ' + target));
			linkCount++;
		}
	}

	var coordSys = seriesModel.get('coordinateSystem');
	var nodeData;

	if (coordSys === 'cartesian2d' || coordSys === 'polar') {
		nodeData = createSeriesData(nodes, seriesModel);
	} else {
		var coordSysCtor = CoordinateSystem.get(coordSys);
		var coordDimensions = coordSysCtor ? coordSysCtor.dimensions || [] : []; // FIXME: Some geo do not need `value` dimenson, whereas `calendar` needs
		// `value` dimension, but graph need `value` dimension. It's better to
		// uniform this behavior.

		if (zrUtil.indexOf(coordDimensions, 'value') < 0) {
			coordDimensions.concat(['value']);
		}

		var dimensions = prepareSeriesDataSchema(nodes, {
			coordDimensions: coordDimensions,
			encodeDefine: seriesModel.getEncode()
		}).dimensions;
		nodeData = new SeriesData(dimensions, seriesModel);
		nodeData.initData(nodes);
	}

	var edgeData = new SeriesData(['value'], seriesModel);
	edgeData.initData(validEdges, linkNameList);
	beforeLink && beforeLink(nodeData, edgeData);
	linkSeriesData({
		mainData: nodeData,
		struct: graph,
		structAttr: 'graph',
		datas: {
			node: nodeData,
			edge: edgeData
		},
		datasAttr: {
			node: 'data',
			edge: 'edgeData'
		}
	}); // Update dataIndex of nodes and edges because invalid edge may be removed

	graph.update();
	return graph;
}